## Cómo acceder a las direcciones de memoria de los bloques IP en Libero

Creador: David Rubio G.

Entrada: <a href="https://soceame.wordpress.com/2025/01/07/como-acceder-a-las-direcciones-de-memoria-de-los-bloques-ip-en-libero/">https://soceame.wordpress.com/2025/01/07/como-acceder-a-las-direcciones-de-memoria-de-los-bloques-ip-en-libero/</a>

Blog: <a href="https://soceame.wordpress.com/">https://soceame.wordpress.com/</a>

GitHub: <a href="https://github.com/DRubioG">https://github.com/DRubioG</a>

Fecha última modificación: 24/02/2025

Para acceder a las direcciones de memoria que adjudica Libero a los bloques IP del SmartDesign, se tiene que tener el SmartDesign con el diseño abierto.



Ahora lo que tenemos que hacer es darle al siguiente icono en la barra de arriba.



Al darle a este botón se abre una pestaña donde figuran todas las direcciones de memoria que tiene el SmartDesign deseado. Aparece la dirección de memoria inicial, el tamaño de la memoria adjudicado y la última dirección de memoria.



También, por ejemplo, tiene apartados específicos con los periféricos que están conectados a un bloque de interconexión, como un *AHB\_TO\_APB* para conectar un bus de direcciones de datos(*AHB*) con un bus de periféricos(*APB*).

| S5_AXI_TO_AHB0_BRIDGE | 0x2000_0000 | -     | -           |
|-----------------------|-------------|-------|-------------|
| ⊟- AHB0               |             |       |             |
| IOSCBCFG              | 0x3708_0000 | 4KB   | 0x3708_0FFF |
| ENVMCFG               | 0x2020_0000 | 4KB   | 0x2020_0FFF |
| □ AHB0_TO_APB0_BRIDGE | 0x2000_0000 | -     | -           |
| ⊟ APB0                |             |       |             |
| H2FINT_LO             | 0x2012_6000 | 4KB   | 0x2012_6FFF |
| MSTIMER_LO            | 0x2012_5000 | 4KB   | 0x2012_5FFF |
| MSRTC_LO              | 0x2012_4000 | 4KB   | 0x2012_4FFF |
| GEM_A_LO              | 0x2011_0000 | 8KB   | 0x2011_1FFF |
| I2C_A_LO              | 0x2010_A000 | 4KB   | 0x2010_AFFF |
| SPI_B_LO              | 0x2010_9000 | 4KB   | 0x2010_9FFF |
| SPI_A_LO              | 0x2010_8000 | 4KB   | 0x2010_8FFF |
| WDOG4_LO              | 0x2010_7000 | 4KB   | 0x2010_7FFF |
| MMUART4_LO            | 0x2010_6000 | 4KB   | 0x2010_6FFF |
| WDOG3_LO              | 0x2010_5000 | 4KB   | 0x2010_5FFF |
| WDOG2_LO              | 0x2010_3000 | 4KB   | 0x2010_3FFF |
| WDOG1_LO              | 0x2010_1000 | 4KB   | 0x2010_1FFF |
| MMUART1_LO            | 0x2010_0000 | 4KB   | 0x2010_0FFF |
| DDRCFG                | 0x2008_0000 | 512KB | 0x200F_FFFF |
| CFG_DDR_SGMII_PHY     | 0x2000_7000 | 4KB   | 0x2000_7FFF |
| FMETER                | 0x2000_6000 | 4KB   | 0x2000_6FFF |
| MPUCFG                | 0x2000_5000 | 4KB   | 0x2000_5FFF |
| AXISW                 | 0x2000_4000 | 4KB   | 0x2000_4FFF |
| SYSREGSCB             | 0x2000_3000 | 4KB   | 0x2000_3FFF |
| SYSREGPRIV            | 0x2000_2000 | 4KB   | 0x2000_2FFF |

Estas direcciones de memoria también se pueden exportar.



Para exportarlo se exporta como un JSON.



Este JSON contiene toda la información de las direcciones de memoria.

```
"title": "Memory Map Report",
"date": "Tue Jan 7 20:10:22 2025",
"project_name": "MPFS_DISCOVERY",
"project_location": "C:\\MPFS_DISCOVERY",
"SmartDesign name": "MPFS_DISCOVERY_KIT",
"Initiator/Bus/Bridge/Target OffsetAddress Range HighAddress":[
{"Node name":"FIC_0_PERIPHERALS_0/DMA_CONTROLLER:AXI4MasterDMA_IF",
"Component name": "DMA_CONTROLLER",
"Type":"Initiator
     e":"Initiator",
"Connected Node":[
         {"Node name": "FIC 0 PERIPHERALS 0/DMA INITIATOR: AXI4mmaster0",
         "Component name": "DMA INITIATOR",
         "Type": "Bus",
              "Connected Node":
         {"Node name": "MSS_WRAPPER_0:FIC_0_AXI4_TARGET",
          "Component name":"MSS_WRAPPER",
         "Offset Address": "0x0000 0000",
         "Range":"4GB",
"High Address":"0xFFFF_FFFF",
         "Type": "Target"
{"Node name":"FIC_3_PERIPHERALS_0/FIC_3_ADDRESS_GENERATION_1/APB_PASS_THROUGH_0:APB_INITIATOR",
"Component name": "APB PASS THROUGH",
"Type": "Initiator",
     "Connected Node":[
         {"Node name":"FIC_3_PERIPHERALS_0/FIC_3_ADDRESS_GENERATION_1/FIC_3_0x4000_0xxx_0:APB3mmaster",
          "Component name": "FIC_3_0x4000_0xxx",
         "Type": "Bus",
              "Connected Node":[
         {"Node name": "PWM: APBslave",
         "Component name": "corepwm_CO",
         "Offset Address": "0x0000 0000",
         "Range":"256B",
"High Address":"0x0000 00FF",
```

Se puede ver las direcciones de memoria que se utilizan.

AitiPs:11SC

```
{"Node name":"I2C A LO",
"Offset Address": "0x2010 A000",
"Range": "4KB",
"High Address":"0x2010_AFFF",
"Type":"Target"
},
{"Node name": "SPI B LO",
"Offset Address": "0x2010 9000",
"Range": "4KB",
"High Address": "0x2010 9FFF",
"Type": "Target"
},
{"Node name": "SPI A LO",
"Offset Address": "0x2010 8000",
"Range": "4KB",
"High Address": "0x2010 8FFF",
"Type": "Target"
},
{"Node name": "WDOG4 LO",
"Offset Address": "0x2010 7000",
"Range": "4KB",
"High Address": "0x2010 7FFF",
"Type": "Target"
},
{"Node name": "MMUART4 LO",
"Offset Address": "0x2010 6000",
"Range": "4KB",
"High Address": "0x2010 6FFF",
"Type": "Target"
```